package cn.com.dcsgo.mapper;

import cn.com.dcsgo.domain.po.SysDept;
import org.apache.ibatis.annotations.Param;

import java.util.List;
import java.util.Set;

/**
 * 针对表【sys_dept(部门表)】的数据库操作Mapper
 *
 * @author Dcsgo
 * @since 2025-05-20 17:30:53
 */
public interface SysDeptMapper {

    int deleteByPrimaryKey(Long id);

    int insert(SysDept record);

    int insertSelective(SysDept record);

    SysDept selectByPrimaryKey(Long id);

    int updateByPrimaryKeySelective(SysDept record);

    int updateByPrimaryKey(SysDept record);

    /**
     * 查询多个部门的信息根据部门id
     *
     * @param deptIds 部门id集合
     * @return 多个部门的信息
     */
    List<SysDept> selectByDeptIds(@Param("deptIds") Set<Long> deptIds);

    /**
     * 查询所有部门信息
     *
     * @return 所有部门信息
     */
    List<SysDept> selectAll();

    /**
     * 根据部门编号判断是否有下级部门
     *
     * @param deptId 部门编号
     * @return 有下级部门返回 true，反之返回 false
     */
    boolean hasChild(@Param("deptId") Long deptId);
}
